草庐IT

c++ - std::string 和 UTF-8 编码的 unicode

全部标签

ruby - 检测编码

我从网络上获取了一些字符串数据,我怀疑它并不总是像它所说的那样。我不知道问题出在哪里,我也不再关心了。从这个项目的第一天起,我就一直在与Ruby字符串编码作斗争。我真的想要某种方式来表达:“这是一个字符串。它是什么?”,然后使用该数据将其转换为UTF-8,这样它就不会爆炸gsub()2,000行在我的应用程序的深处。我已经查看了rchardet,但即使它现在应该适用于1.9,它也会在给定任何多字节输入的情况下崩溃......这没有帮助。 最佳答案 您无法真正检测到编码。你只能假设它。对于大多数西方语言应用程序,以下构造将工作。传统的

ruby - Ruby 中用于 "String#include?"的算法

有谁能指出包含的算法是什么?Ruby中的方法?例如"helloworld".include?("hello") 最佳答案 正如emboss在他的回答中所述,String#include调用rb_str_index。此函数依次调用rb_memsearch,它实现了Rabin-Karpstringsearchalgorithm,根据thispost在ruby-forum.com上。 关于ruby-Ruby中用于"String#include?"的算法,我们在StackOverflow上找到一

Ruby on Rails 上传文件问题 奇数 utf8 转换错误

我正在尝试上传文件,但出现以下错误:"\xFF"fromASCII-8BITtoUTF-8我非常关注Rails指南的工作。这是我正在使用的代码。file=params[:uploaded_file]File.open(Rails.root.join('public','images',file.original_filename),'w')do|f|f.write(file.read)end我不明白为什么它不起作用。我做错了什么?更新--这是应用程序跟踪app/controllers/shows_controller.rb:16:in`write'app/controllers/sho

ruby - 在 Ruby 中打开和保存 base64 编码的图像数据 URI

从我看过的几个帖子来看,我正在尝试这个x=Base64.decode64("data:image/png;base64,iVBOR....")File.open('test.png','wb'){|file|file.writex}但是我无法用查看器打开图像,我是否需要做更多的事情? 最佳答案 您的问题是您试图将'data:image/png;base64,'前缀解码为Base64数据;该前缀是完全有效的Base64数据,但它不是PNG文件的Base64表示形式。结果是您的test.png文件包含一堆废话,后面跟着一些实际上是PNG

ruby - 如何将 unicode 单词与 ruby​​ 1.9 匹配?

我正在使用ruby​​1.9并试图找出我需要哪个正则表达式来实现这一点:Encoding.default_internal=Encoding.default_external='utf-8'"föö".match(/(\w+)/u)[1]=="föö"#=>false 最佳答案 #encoding=utf-8p"föö".match(/\p{Word}+/)[0]=="föö" 关于ruby-如何将unicode单词与ruby​​1.9匹配?,我们在StackOverflow上找到一个类

ruby-on-rails - Ruby/Rails 3.1 : Given a URL string, 删除路径

给定任何有效的HTTP/HTTPS字符串,我想解析/转换它,以便最终结果恰好是字符串的根。因此给出的URL:http://foo.example.com:8080/whatsit/foo.bar?x=yhttps://example.net/我想要结果:http://foo.example.com:8080/https://example.net/我找到了documentation对于URI::Parser不是super平易近人。我最初的天真解决方案是一个简单的正则表达式,例如:/\A(https?:\/\/[^\/]+\/)/(即:匹配协议(protocol)后的第一个斜杠。)欢迎提

ruby - 如何使用 ruby​​ 1.9 转换字符编码

我目前在处理来自亚马逊API的结果时遇到问题。该服务返回一个带有unicode字符的字符串:在Mac上学习Objective\xE2\x80\x93C(学习系列)使用ruby​​1.9.1甚至无法处理字符串:REXML::ParseException:#...ExceptionparsingLine:1Position:1636Last80unconsumedcharacters:LearnObjective–ContheMac(LearnSeries) 最佳答案 作为异常(exception)点,您的字符串是ASCII-8BIT编

ruby - 如何解决 Puppet 的编码问题

我在Puppet的文件编码hell中。即使是最简单的尝试也行不通:hiera-data/test.yaml:---test:Äñöinit.pp:$test=hiera('test')file{"/root/encoding.txt":ensure=>file,content=>$test}在Puppet服务器上一切看起来都很好:puppet:~#file-i/etc/puppetlabs/puppet/hiera-data/env/test.yaml/etc/puppetlabs/puppet/hiera-data/env/test.yaml:text/plaincharset=ut

ruby-on-rails - 编码未定义的转换错误 - Ruby on Rails,写入错误

所以我试图从网站下载一个zip文件并将该数据放入一个表中。下载之前一直在工作,但突然之间,它不再是了。我得到一个“‘write’:“\xB6”fromASCII-8BITtoUTF-8(Encoding::UndefinedConversionError)”的问题。很奇怪,自从我上次运行脚本以来没有任何变化。这是有问题的代码部分。我正在使用一个gem,它允许我在zip文件中解析DBF文件。代码如下:`write':"\xB6"fromASCII-8BITtoUTF-8(Encoding::UndefinedConversionError)感谢帮助更新:显然,我在rails内运行。我在r

c - Ruby C 扩展开发人员的命名约定

在用C为ruby​​编写扩展时,我对遵循正确的命名约定很感兴趣。具体来说,我指的是将_p添加到谓词的函数名称以及为变量添加前缀m代表模块,c代表类等等。例如,如果我们想在C语言中定义一个像下面这样的谓词方法,我们应该在定义该方法的函数中使用_p作为后缀。classMyClassdefawesome?trueendend在C中:staticVALUEmy_extension_my_class_awesome_p(VALUEself){returnQtrue;}voidInit_my_extension(void){VALUEcMyClass=rb_define_class("MyClas